草庐IT

php - PHP调用SQL外键数据

全部标签

ruby-on-rails - 是否有与 PHP 的 isset() 等效的 Rails?

基本上只是检查以确保设置了url参数。我如何在PHP中做到这一点:if(isset($_POST['foo'])&&isset($_POST['bar'])){}这是RoR中isset()的粗略/最佳等价物吗?if(!params['foo'].nil?&&!params['bar'].nil?)end 最佳答案 更接近的匹配可能是#present?#returnstrueifnotnilandnotblankparams['foo'].present?还有一些其他的方法#returnstrueifnilparams['foo'].

ruby-on-rails - 将外键添加到 Rails 模型

我是Rails的新手,整晚都在尝试解决这个问题,但没有成功。我创建了3个模型:users、businesses和business_hours。我还添加了关联(business_hoursbelongs_tobusinesseswhichbelongs_tousers)和(userhas_onebusinesswhichhas_manybusiness_hours)。通过在线阅读文档,我现在似乎需要在我的数据库表中为这些关系创建外键。我如何使用RailsActiveRecord迁移来做到这一点?我使用PostgreSQL作为我的数据库。 最佳答案

ruby-on-rails - 如何检查 ActiveRecord 使用的数据库名称

在database.yml中定义所有设置。如何从ruby​​访问这些设置?我查看了App::Application::config,但在那里找不到它。另外,我记得人们可以在没有yaml的情况下配置数据库设置,有人知道怎么做吗? 最佳答案 Rails.configuration.database_configuration这将为您提供一个哈希表,其中包含每个环境的配置。例如。获取您的开发数据库名称:Rails.configuration.database_configuration["development"]["database"]

ruby - Rails 控制台中没有数据库连接

当我运行rakedb:migrate时,我的Rails应用程序工作正常,但当我尝试启动Rails控制台时出现问题。2.0.0p247:003>User=>User(nodatabaseconnection) 最佳答案 这是由于ActiveRecord从4.0开始懒惰地建立连接。别担心。第一次建立后,您将开始看到预期的输出。试试这个:2.1.4:001>User#=>User(call'User.connection'toestablishaconnection)2.1.4:001>User.count#=>SELECTCOUNT(*

ruby-on-rails - rake 数据库 :reset 'user does not have CONNECT privilege'

所以我在我的Rails应用程序中使用HerokuPostgres,但我没有在Heroku本身上托管我的应用程序。我在我的database.yml中使用了来自Heroku的ActiveRecord连接详细信息,它看起来像这样:development:adapter:postgresqlencoding:unicodepool:5database:[database]username:[username]password:[password]host:ec2-54-227-243-78.compute-1.amazonaws.comport:5432但是,现在我正在尝试rakedb:mig

Ruby 在调用方法之前检查是否为 nil

我在Ruby中有一个字符串,我在其上调用strip方法来删​​除前导和尾随空格。例如s="12345"s.strip但是,如果字符串为emptynil,我会收到以下错误。NoMethodError:undefinedmethod`strip'fornil:NilClass我使用的是Ruby1.9,那么在调用strip方法之前检查值是否为nil的最简单方法是什么?更新:我在数组中的一个元素上试过这个但遇到了同样的问题:data[2][1][6].nil??data[2][1][6]:data[2][1][6].split(":")[1].strip 最佳答案

ruby-on-rails - 您如何查看 ruby​​ 中的调用堆栈示例?

我正在研究不同的优化技术,我发现了这篇文章AnalyzingCodeforEfficiency?相信对调用堆栈进行采样比使用分析器更有效的人。基本思想是,如果您查看调用堆栈,您会看到您的应用程序最有可能花费大部分时间的地方,然后在那里进行优化。这当然很有趣,而且他显然是这方面的专家,但我不知道如何在ruby中查看调用堆栈。在调试器中,我可以说“信息堆栈”,但似乎只显示一行。编辑:我看到MikeDunlavey的评论:“我只想指出,如果你在调试器下运行,手动中断它,并显示调用堆栈......”我只是不确定如何手动中断它并隐藏调用堆栈。 最佳答案

ruby - 截断、事务和删除数据库策略之间的区别

使用Rspec时截断、事务和删除数据库策略有什么区别?我找不到任何资源来解释这一点。我阅读了DatabaseCleaner自述文件,但它没有解释它们各自的作用。为什么我们必须对capybara使用截断策略?我是否必须在测试时清理我的数据库,或者我可以禁用它。我不明白为什么我应该在每个测试用例之后清理我的数据库,这不会减慢测试速度吗? 最佳答案 数据库清理策略引用数据库术语。IE。这些术语来自(SQL)数据库世界,因此通常熟悉数据库术语的人会知道它们的含义。以下示例引用了SQL定义。DatabaseCleaner也支持其他非SQL类型

ruby-on-rails - 在 Rails 中添加可为空的外键

引用Rails4.2add_foreign_key支持:#addaforeignkeyto`articles.author_id`referencing`authors.id`add_foreign_key:articles,:authors如何创建可为null的外键约束,以允许articles.author_id有时可以为null的情况? 最佳答案 请注意,在Rails5和在Rails6中如果它是1:n(belongs_to),因为默认值已更改:belongs_to:author,可选:true这是对应的Changeset.要在整

ruby - 如何获取字符串中所有出现的 Ruby 正则表达式的匹配数据?

对于字符串中正则表达式的每次出现,我都需要MatchData。这与MatchAllOccurrencesofaRegex中建议的扫描方法不同,因为这只会给我一个字符串数组(我需要完整的MatchData,以获取开始和结束信息等)。input="abc12def34ghijklmno567pqrs"numbers=/\d+/numbers.matchinput##(onlythefirstmatch)input.scannumbers#["12","34","567"](allmatches,butonlythestrings)我怀疑我忽略了某些方法。有什么建议吗?